<!--
  ~ Licensed to the Apache Software Foundation (ASF) under one or more
  ~ contributor license agreements.  See the NOTICE file distributed with
  ~ this work for additional information regarding copyright ownership.
  ~ The ASF licenses this file to You under the Apache License, Version 2.0
  ~ (the "License"); you may not use this file except in compliance with
  ~ the License.  You may obtain a copy of the License at
  ~
  ~    http://www.apache.org/licenses/LICENSE-2.0
  ~
  ~ Unless required by applicable law or agreed to in writing, software
  ~ distributed under the License is distributed on an "AS IS" BASIS,
  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  ~ See the License for the specific language governing permissions and
  ~ limitations under the License.
  -->

<div class="local-changes-table h-full flex flex-col">
    <div>
        <div>
            <form [formGroup]="filterForm" class="my-2">
                <div class="flex pt-2">
                    <div class="mr-2">
                        <mat-form-field subscriptSizing="dynamic">
                            <mat-label>Filter</mat-label>
                            <input matInput type="text" class="small" formControlName="filterTerm" />
                        </mat-form-field>
                    </div>
                </div>
            </form>
            <div class="my-2 tertiary-color leading-none font-medium">
                Displaying {{ filteredCount }} of {{ totalCount }}
            </div>
        </div>
    </div>
    <div class="listing-table flex-1 relative">
        <div class="absolute inset-0 overflow-y-auto overflow-x-hidden">
            <table
                mat-table
                [dataSource]="dataSource"
                matSort
                matSortDisableClear
                (matSortChange)="sortData($event)"
                [matSortActive]="initialSortColumn"
                [matSortDirection]="initialSortDirection">
                <!-- Context column -->
                <ng-container matColumnDef="componentName">
                    <th mat-header-cell *matHeaderCellDef mat-sort-header>Component Name</th>
                    <td mat-cell *matCellDef="let item" [title]="formatComponentName(item)">
                        {{ formatComponentName(item) }}
                    </td>
                </ng-container>

                <!-- Name Column -->
                <ng-container matColumnDef="changeType">
                    <th mat-header-cell *matHeaderCellDef mat-sort-header>Change Type</th>
                    <td mat-cell *matCellDef="let item" [title]="formatChangeType(item)">
                        {{ formatChangeType(item) }}
                    </td>
                </ng-container>

                <!-- Value column -->
                <ng-container matColumnDef="difference">
                    <th mat-header-cell *matHeaderCellDef mat-sort-header>Difference</th>
                    <td mat-cell *matCellDef="let item" [title]="formatDifference(item)">
                        {{ formatDifference(item) }}
                    </td>
                </ng-container>

                <ng-container matColumnDef="actions">
                    <th mat-header-cell *matHeaderCellDef></th>
                    <td mat-cell *matCellDef="let item">
                        <div class="flex items-center justify-end gap-x-2">
                            @if (canGoTo(item)) {
                                <button
                                    mat-icon-button
                                    type="button"
                                    [matMenuTriggerFor]="actionMenu"
                                    class="h-16 w-16 flex items-center justify-center icon global-menu">
                                    <i class="fa fa-ellipsis-v"></i>
                                </button>
                                <mat-menu #actionMenu="matMenu" xPosition="before">
                                    <button mat-menu-item (click)="goToClicked(item)">
                                        <i class="fa fa-long-arrow-right primary-color mr-2"></i>
                                        Go To
                                    </button>
                                </mat-menu>
                            }
                        </div>
                    </td>
                </ng-container>

                <tr mat-header-row *matHeaderRowDef="displayedColumns; sticky: true"></tr>
                <tr mat-row *matRowDef="let row; let even = even; columns: displayedColumns" [class.even]="even"></tr>
            </table>
        </div>
    </div>
</div>
